

| Problem | Category                                  | Pattern / Specific Error                                               | Freq. |
|---------|-------------------------------------------|------------------------------------------------------------------------|-------|
| P6      | 3. Omission of Critical Instructions      | Fails to calculate the SIMD loop's iteration count.                    | 1     |
| P7      | 4. Incorrect Instruction-Level            | Pattern 4.3: Incorrect Instruction Ordering (resets variable           |       |
|         | Semantics                                 | before storing it).                                                    | 1     |
| D0      | 1. Incorrect Register State               | Pattern 1.1: Premature Update (increments index before using it        | _     |
| P8      | Management                                | for a store).                                                          | 1     |
|         | 3. Omission of Critical                   | 1. Fails to initialize SIMD product vectors.<br>str>2. Omits the final | 2     |
| P9      | Instructions                              | SIMD reduction step.                                                   |       |
|         | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering (overwrites sum vectors during        | _     |
|         | Management                                | multiplication).                                                       | 1     |
|         | 2. Flawed Control Flow and                | Pattern 2.2: Premature/Incorrect Return (returns an integer            |       |
| P10     | Logic                                     | instead of a pointer via a bad branch).                                | 1     |
| P15     | Incorrect Instruction-Level     Semantics | Pattern 4.1: Invalid Addressing Mode (uses [x0, x0]).                  | 1     |
|         | 5. Literal Translation Artifacts          | Mimics a complex shl/sar trick for multiplication instead of           | _     |
|         | (x86-isms)                                | using a single lsl/sbfiz.                                              | 1     |
| _       | 1. Incorrect Register State               | Pattern 1.3: Failure to Propagate Return Values (omits mov x21,        | 1     |
| P18     | Management                                | x0 after realloc).                                                     |       |
|         | 2. Flawed Control Flow and                | Pattern 2.1: Incorrect Branch Target (branches to a loop instead       | _     |
|         | Logic                                     | of the error handler).                                                 | 1     |
|         | 4. Incorrect Instruction-Level            | Pattern 4.2: Incorrect Immediate Value (1. Wrong stack offset.         |       |
|         | Semantics                                 | 2. Wrong constant for a note).                                         | 2     |
| 510     | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering (overwrites the main loop             | 1     |
| P19     | Management                                | counter with an input value).                                          |       |
|         | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering (overwrites original character        | 1     |
| P20     | Management                                | with lowercase version before store).                                  |       |
|         | 4. Incorrect Instruction-Level            | Pattern 4.2: Incorrect Immediate Value (uses wrong ASCII               |       |
|         | Semantics                                 | values for comparisons).                                               | 1     |
| 201     | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering (min_diff register s2 is              | 1     |
| P21     | Management                                | overwritten inside the loop).                                          |       |
|         | 4. Incorrect Instruction-Level            | Pattern 4.2: Incorrect Immediate Value (fails to move FLT_MAX          |       |
|         | Semantics                                 | into a float register).                                                | 1     |
| DOC     | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering (Calculates min/max into              | 1     |
| P22     | Management                                | s4/s3 but later code incorrectly reads from s0/s1).                    |       |
| DOC     | 3. Omission of Critical                   | Fails to advance the main string pointer (mov x20, x9) after           | 1     |
| P23     | Instructions                              | parsing a number, causing an infinite loop.                            |       |

| Problem    | Category                                | Pattern / Specific Error                                          | Fre |
|------------|-----------------------------------------|-------------------------------------------------------------------|-----|
|            | Incorrect Register State                | Fails to use the return value from strtol (in w0), storing a      | 1   |
|            | Management                              | garbage character from w8 instead.                                | '   |
| P27        | Incorrect Register State     Management | 1. Pattern 1.2: Register Clobbering (inner loop counter corrupts  |     |
|            |                                         | outer loop's index).<br>>2. Stores a loop counter instead of an   | 2   |
|            |                                         | array element.                                                    |     |
|            | 3. Omission of Critical Instructions    | Fails to initialize a separate counter for an inner loop.         | 1   |
| DOO        | 7. Misinterpretation of                 | Grossly incorrect SIMD implementation (unrolls to 64 bytes and    | 1   |
| P28        | Algorithm's Goal                        | botches logic).                                                   |     |
|            | 3. Omission of Critical                 | Completely omits the logic for swapping uppercase to              | 1   |
|            | Instructions                            | lowercase in the scalar path.                                     |     |
| D00        | 1. Incorrect Register State             | Fails to preserve the array pointer for a second pass,            | _   |
| P29        | Management                              | consuming it in the first loop.                                   | 1   |
| <b>DOS</b> | 1. Incorrect Register State             | 1. Fails to update the main state variable (d0).<br>2. Calculates | _   |
| P33        | Management                              | powers of the wrong variable.                                     | 2   |
|            | 2. Flawed Control Flow and              | Incorrect branching; falls through into hallucinated code instead |     |
|            | Logic                                   | of looping correctly.                                             | 1   |
|            | 9. Code Hallucination                   | Generates several blocks of nonsensical, spurious code.           | 1   |
|            | Incorrect Register State                | Initializes an inner loop counter with the array element's value  | 1   |
| P35        | Management                              | instead of the count of items to check.                           |     |
|            | 3. Omission of Critical                 | Completely omits the function epilogue (updating out_count,       |     |
|            | Instructions                            | restoring registers, ret).                                        | 1   |
|            | 1. Incorrect Register State             | Resets the max_val register back to its initial small value in    | 1   |
| P36        | Management                              | every loop iteration.                                             |     |
|            | 7. Misinterpretation of                 | Fails to translate compound conditional logic, incorrectly        |     |
| P37        | Algorithm's Goal                        | merging two independent checks with ccmp.                         | 1   |
|            | 3. Omission of Critical Instructions    | Omits a key mul instruction needed for a conditional check.       | 1   |
| DOO        | 6. Incorrect Loop Pointer/Index         | Fails to advance the main SIMD source pointer, causing an         | 1   |
| P38        | Management                              | infinite loop on the same data.                                   |     |
|            | 3. Omission of Critical                 | Completely omits the final merging loop that constructs the       |     |
|            | Instructions                            | output array.                                                     | 1   |
|            | 2. Flawed Control Flow and              | Pattern 2.1: Incorrect Branch Target (branches out of an inner    | _   |
|            | Logic                                   | sort loop prematurely).                                           | 1   |
|            | 1. Incorrect Register State             | Operates on a copy of the main state variable (n), which is       | 1   |
| P40        | Management                              | never updated inside the inner loop.                              |     |

| Problem | Category                                        | Pattern / Specific Error                                                                                                           | Freq. |
|---------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------|
|         | Flawed Control Flow and Logic                   | Unconditional branch in a nested loop creates an infinite loop.                                                                    | 1     |
| P41     | Incorrect Register State     Management         | Pattern 1.2: Register Clobbering (Completely corrupts all loop iterators and flags at setup).                                      | 1     |
|         | 7. Misinterpretation of Algorithm's Goal        | Fails to understand the j+k < size loop condition, checking k < size instead.                                                      | 1     |
|         | Elawed Control Flow and Logic                   | Pattern 2.2: Premature/Incorrect Return (exits immediately on first match instead of continuing search).                           | 1     |
| P44     | Incorrect Register State     Management         | Pattern 1.2: Register Clobbering (Completely corrupts loop iterators and flags at setup, similar to P41).                          | 1     |
|         | 2. Flawed Control Flow and Logic                | Pattern 2.2: Premature/Incorrect Return (exits immediately on first match).                                                        | 1     |
| P45     | 6. Incorrect Loop Pointer/Index Management      | Uses a stagnant (never incremented) write pointer, overwriting out_str[0] in every loop iteration.                                 | 1     |
|         | 8. Failure to Generate Idiomatic/Optimized Code | Fails to generate the optimized SIMD path (rev64.8b) for string reversal.                                                          | 1     |
| P47     | 6. Incorrect Loop Pointer/Index<br>Management   | Instruction Reordering: The relative order of ldr and pointer updates is wrong, causing the recurrence relation to use stale data. | 1     |
| P50     | Incorrect Register State     Management         | Pattern 1.4: Incorrect Source/Destination in Update: Fails to use the running result as input for the next iteration.              | 1     |
| P51     | 9. Code Hallucination                           | Generates a nonsensical, 500+ instruction block instead of a simple SIMD loop.                                                     | 1     |
|         | 3. Omission of Critical Instructions            | Completely omits the scalar fallback path for short strings.                                                                       | 1     |
| P60     | Incorrect Register State     Management         | Operates on a temporary copy of n inside the "divide out" loop, so n is never updated.                                             | 1     |
|         | Flawed Control Flow and Logic                   | Unconditional branch in the "divide out" loop creates an infinite loop.                                                            | 1     |
| P63     | Incorrect Instruction-Level     Semantics       | Pattern 4.1: Invalid Addressing Mode: Provides a pre-scaled offset where a raw index is expected, causing double scaling.          | 1     |
| P64     | Incorrect Memory     Addressing and Management  | Uses incorrect stack offsets for its temporary array.                                                                              | 1     |
|         | 6. Incorrect Loop Pointer/Index Management      | str instruction corrupts the base pointer used for Idur in the next iteration.                                                     | 1     |
|         | Incorrect Register State     Management         | Fails to preserve the input n, using an uninitialized register for the final read index.                                           | 1     |

| Problem | Category                                  | Pattern / Specific Error                                                                                      | Free     |
|---------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------|
| P65     | 1. Incorrect Register State               | Consumes the main string pointer in the first loop, so it's invalid                                           | 1        |
|         | Management                                | for the second operation (reading the last character).                                                        | 1        |
|         | 7. Misinterpretation of                   | Incorrectly translates a simple ifthen into a flawed csinc                                                    |          |
|         | Algorithm's Goal                          | instruction.                                                                                                  | 1        |
| D. (    | 4. Incorrect Memory                       | Uses an incorrect and dangerously small stack offset for a                                                    |          |
| P66     | Addressing and Management                 | temporary buffer, risking a buffer overflow.                                                                  | 1        |
|         | 2. Flawed Control Flow and                | Pattern 2.1/2.2: Incorrect branching after main logic fails to set                                            |          |
|         | Logic                                     | the return value correctly for one code path.                                                                 | 1        |
|         | 7. Misinterpretation of                   | Fails to translate a compound conditional for state switching,                                                | 1        |
| P68     | Algorithm's Goal                          | producing jumbled ccmp/csel logic.                                                                            |          |
|         | Incorrect Register State                  | Uses the wrong length register (len1) as the index into the                                                   |          |
|         | Management                                | second number's buffer.                                                                                       | 1        |
|         | 6. Incorrect Loop Pointer/Index           | Instruction Reordering: Decrements a "from-end" index before                                                  | 1        |
| P71     | Management                                | the ldr, causing an off-by-one read.                                                                          |          |
|         | Incorrect Register State                  | Pattern 1.1: Premature Update: Increments the output write                                                    | 1        |
|         | Management                                | index before all writes for the current iteration are complete.                                               |          |
|         | Incorrect Register State                  | Pattern 1.2: Register Clobbering: Destroys input registers (a, b,                                             | 1        |
| P72     | Management                                | c) during the Triangle Inequality check.                                                                      |          |
|         | _                                         | , , ,                                                                                                         | <u> </u> |
|         | 7. Misinterpretation of Algorithm's Goal  | Fails to understand that the inequality check requires all original values, leading to the state destruction. | 1        |
|         |                                           | , , , , , , , , , , , , , , , , , , ,                                                                         | ₩        |
| P76     | 1. Incorrect Register State               | Operates on a temporary copy of n inside the "divide out" loop,                                               | 1        |
|         | Management                                | so n is never updated. (Same as P60).                                                                         |          |
|         | 2. Flawed Control Flow and                | Unconditional branch in the "divide out" loop creates an infinite                                             | 1        |
|         | Logic                                     | loop. (Same as P60).                                                                                          | <u> </u> |
| P77     | 7. Misinterpretation of                   | Incorrectly merges two independent loop conditions (power > n                                                 | 1        |
|         | Algorithm's Goal                          | and count < 100) into a single faulty ccmp.                                                                   |          |
|         | Incorrect Register State                  | Unconditionally increments the loop counter, even on the final                                                | 1        |
|         | Management                                | iteration that exits the loop.                                                                                | Ĺ        |
| P81     | 1. Incorrect Register State               | Pattern 1.2: Register Clobbering: The fixed pattern character                                                 | 1        |
| roi     | Management                                | register is overwritten inside the loop.                                                                      |          |
|         | 7. Misinterpretation of                   | Completely misinterprets the loop's comparison logic.                                                         | 1        |
|         | Algorithm's Goal                          | Completely mainterprets the 100ps companson logic.                                                            |          |
|         | Incorrect Instruction-Level     Semantics | Pattern 4.2: Loads incorrect floating-point constants for grade                                               | 2        |
| P82     |                                           | thresholds.<br>Pattern 4.1: Uses an invalid addressing mode                                                   |          |
|         | - Germanuca                               | (str x0, [x0]).                                                                                               |          |
|         | 6. Incorrect Loop Pointer/Index           | Uses a stagnant output pointer, writing every result to                                                       | 1        |
|         | Management                                | out_array[0].                                                                                                 | 1        |

| Problem | Category                        | Pattern / Specific Error                                           | Freq. |
|---------|---------------------------------|--------------------------------------------------------------------|-------|
| P85     | 6. Incorrect Loop Pointer/Index | Uses incorrect pointer arithmetic to advance through a string.     | 1     |
|         | Management                      |                                                                    | ı     |
|         | 2. Flawed Control Flow and      | Uses an incorrect termination condition for a string reversal      | 1     |
|         | Logic                           | loop.                                                              |       |
| P86     | 1. Incorrect Register State     | Pattern 1.2: Register Clobbering: A register holding a loop index  | 1     |
|         | Management                      | is overwritten by a SIMD result before it's used.                  |       |
| P87     | 1. Incorrect Register State     | 1. Fails to initialize a pointer for the inner sort loop.<br>br>2. | 2     |
|         | Management                      | Pattern 1.1: Premature Update (resets word length before use).     | _     |
|         |                                 |                                                                    |       |

## **Summary Statistics**

**Total Problems Analyzed:** 45 problems (P6-P87, excluding gaps)

## **Category Distribution:**

- Category 1 (Incorrect Register State Management): Most frequent category
- Category 2 (Flawed Control Flow and Logic): Second most common
- Category 3 (Omission of Critical Instructions): Significant occurrence
- Category 4 (Incorrect Instruction-Level Semantics): Multiple patterns identified
- Category 6 (Incorrect Loop Pointer/Index Management): Common in loop-heavy algorithms
- Category 7 (Misinterpretation of Algorithm's Goal): Complex logic translation issues
- Category 8 (Failure to Generate Idiomatic/Optimized Code): Optimization failures
- Category 9 (Code Hallucination): Rare but severe errors

## **Key Patterns:**

- Pattern 1.1: Premature Update
- Pattern 1.2: Register Clobbering (most common)
- Pattern 1.3: Failure to Propagate Return Values
- Pattern 1.4: Incorrect Source/Destination in Update
- Pattern 2.1: Incorrect Branch Target
- Pattern 2.2: Premature/Incorrect Return
- Pattern 4.1: Invalid Addressing Mode
- Pattern 4.2: Incorrect Immediate Value
- Pattern 4.3: Incorrect Instruction Ordering